<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>01-js 的抖动</title>
    <style>
        .box {
            width: 600px;
            height: 1500px;
            background-color: pink;
            margin: 0 auto;
        }
    </style>
</head>

<body>
    <div class="box"></div>
</body>
<script>

    // 封装一个节流的函数
    function jiuliu(wait, cb) {
        // 定义一个开始的时间
        var beginTime = Date.now()
        // 定义一个定时器
        var timer = null
        return function () {
            // 清除定时器
            clearTimeout(timer) // 使用闭包
            // 定时一个执行 onscroll 的时间
            var currentTime = Date.now()
            // 得到时间间隔
            var space = currentTime - beginTime
            // 判断
            if (space >= wait) {
                cb()
                // 保存当前执行的时间为下一次执行的开始时间
                beginTime = Date.now()
            } else {
                timer = setTimeout(() => {
                    cb()
                }, wait)
            }
        }
    }
    window.onscroll = jiuliu(1000, () => {
        console.log('onscroll')
    })
</script>

</html>